﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

using MakeIT.Deo.Negocios;
using System.Configuration;

namespace MakeIT.Deo.Apresentacao
{
    public partial class AreaRestrita : System.Web.UI.UserControl
    {
        protected usuario usuarioVO = null;
        string captcha = null;

        protected void Page_Load(object sender, EventArgs e)
        {
            usuarioVO = (usuario)this.Session["userActive"];
            captcha = (string)this.Session["captcha"];

            if (usuarioVO == null)
            {
                this.PanelLogin.Visible = true;
                this.PanelUsuarioAutenticado.Visible = false;

                this.TextBoxUsuario.Focus();
            }
            else
            {
                this.PanelLogin.Visible = false;
                this.PanelUsuarioAutenticado.Visible = true;
                LabelUsuarioAutenticado.Text = usuarioVO.User;
           }

        }

        protected void ImageButton1_Click(object sender, ImageClickEventArgs e)
        {
            string user = this.TextBoxUsuario.Text;
            string pass = this.TextBoxSenha.Text;
            string capt = this.TextBoxCaptcha.Text;

            if (user.Trim().Length > 0 && pass.Trim().Length > 0 && capt.Trim().Length>0)
            {
                if (capt.ToUpper().Trim().Equals(captcha))
                {
                    if (user.Equals(ConfigurationManager.AppSettings["Admin.Nome"]))
                    {
                        if (pass.Equals(ConfigurationManager.AppSettings["Admin.Pass"]))
                        {
                            usuarioVO = new usuario();
                            usuarioVO.IdUsuario = -999999999;
                            usuarioVO.User = ConfigurationManager.AppSettings["Admin.Nome"] + " (Adm)";

                            this.Session["userActive"] = usuarioVO;
                            Response.Redirect("~/BackOffice.aspx");
                        }
                        else
                        {
                            this.LabelMensagem.Text = "Usuário/Senha incorretos";
                        }

                    }
                    else
                    {
                        UsuarioBO usuarioBO = new UsuarioBO();
                        List<usuario> listaUsuario = usuarioBO.RecuperaUsuario(null, null, user, true);

                        if (listaUsuario != null && listaUsuario.Count > 0)
                        {
                            usuario usuVO = listaUsuario[0];
                            if (usuVO.Pass.Equals(pass))
                            {

                                usuarioVO = new usuario();
                                usuarioVO.IdUsuario = usuVO.IdUsuario;
                                usuarioVO.User = usuVO.User + " (op)";

                                this.Session["userActive"] = usuarioVO;
                                Response.Redirect("~/BackOffice.aspx");
                            }
                            else
                            {
                                this.LabelMensagem.Text = "Usuário/Senha incorretos";
                            }
                        }
                        else
                        {
                            this.LabelMensagem.Text = "Usuário não encontrado";
                        }
                    }
                }
                else
                {
                    this.LabelMensagem.Text = "Código de segurança incorreto";
                }
            }
            else
            {
                this.LabelMensagem.Text = "Usuário/Senha/Código não informados";
            }

        }

        protected void ButtonUsuarioAutenticado_Click(object sender, EventArgs e)
        {
            Response.Redirect("~/BackOffice.aspx");
        }

        protected void ButtonEncerrarSessao_Click(object sender, EventArgs e)
        {
            Session["userActive"] = null;
            Response.Redirect("~/BackOffice.aspx");
        }
    }
}